<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>自定义指令</title>
    <!-- 引入Vue -->
    <script type="text/javascript" src="../node_modules/vue/dist/vue.js"></script>
</head>
<body>
    <!--
        需求1：定义一个 v-big 指令，和 v-text 功能类似，但是会把绑定的数值放大 10 倍
        需求2：定义一个 v-fbind 指令，和 v-bind 类似，但是可以让其所绑定的 input 元素默认获取焦点

        自定义指令总结：
		一、定义语法：
			(1).局部指令：
				new Vue({								new Vue({
					directives:{指令名:配置对象}   或   		directives{指令名:回调函数}
				}) 										})
			(2).全局指令：
			    Vue.directive(指令名,配置对象) 或  Vue.directive(指令名,回调函数)

		二、配置对象中常用的 3 个回调：
			(1).bind：指令与元素成功绑定时调用。
			(2).inserted：指令所在元素被插入页面时调用。
			(3).update：指令所在模板结构被重新解析时调用。

		三、备注：
			1.指令定义时不加 v-，但使用时要加 v-；
			2.指令名如果是多个单词，要使用 kebab-case 命名方式，不要用 camelCase 命名。
    -->
    <div id="root">
        <h2>当前的n值是：<span v-text="n"></span></h2>
        <h2>放大10倍后的n值是：<span v-big="n"></span></h2>
        <h2>放大10倍后的n值是：<span v-big-number="n"></span></h2>
        <button @click="n++">点我n+1</button>
        <input type="text" v-fbind:value="n">
    </div>
</body>
<script type="text/javascript">

    //定义全局指令
    /* Vue.directive('fbind',{
        //指令与元素成功绑定时（一上来）
        bind(element,binding){
            element.value = binding.value
        },
        //指令所在元素被插入页面时
        inserted(element,binding){
            element.focus()
        },
        //指令所在的模板被重新解析时
        update(element,binding){
            element.value = binding.value
        }
    }) */

    new Vue({
        el: '#root',
        data: {
            n:1
        },
        directives: {
            // big函数何时会被调用？1.指令与元素成功绑定时（一上来）。2.指令所在的模板被重新解析时（比如 data 中的数据发生变化时）。
            // ===> bind + update
            big(element, binding) {
                // 注意，此处的 this 是 window
                console.log('big', this);
                element.innerText = binding.value * 10;
            },
            'big-number':function(element, binding) {
                console.log('big');
                element.innerText = binding.value * 10;
            },
            fbind: {
                // 指令与元素成功绑定时
                bind(element, binding) {
                    element.value = binding.value;
                },
                // 指令所在元素被插入页面时
                inserted(element, binding) {
                    element.focus();
                },
                // 指令所在的模板被重新解析时
                update(element, binding) {
                    element.value = binding.value;
                }
            }
        }
    })
</script>
</html>